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Section A 


1 The temperatures of an ocean are input into a computer system. They are recorded, and will be 
accessed, in the order in which they arrive. The data for one week is shown: 


5, 5.5, 5, 6, 7, 6.5, 6 


(a) The data is to be stored in a data structure. The programmer stores the data in a queue. 


Explain why a queue is used instead of a stack. 


(b) The data is processed. After processing, the value for the first day is stored as 0. The value 
for each following day is stored as an increase, or decrease, from the first day. 


For example: if the first day was 7, the second was 6 and the third was 9, after processing it 
would be stored as 0, —1, 2. 


(i) The queue uses dequeue( ) to return the first element of the queue. 


(ii) 
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dequeue( ) is a function. 


Explain why dequeue( ) is a function, not a procedure. 


Complete the algorithm to process the data in the queue and store the results in an array 
called processedData. 


processedData[0] = 0 
TLPSUtD Ay = avnsveitvandanianiiscinesn 
for count = 1 to 6 
PrOCESSCUD aC a | euiiciencn: |] = deqQueue(). = cccunseniccceis 


next count 


[3] 
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(iii) The contents of processedData are shown. 


0 0.5 0 uy 2 125 i 


The data needs to be sorted into ascending order. 


Explain how a bubble sort algorithm sorts data. Use the current contents of 
processedData in your explanation. 
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4 
(iv) A bubble sort has the following complexities: 


Best time O(n) 
Average and worst time O(n?) 
Worst space O(1) 


Describe what each of these complexities mean. 


Best time O(n) 
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A program needs to store the names of plants that are in a garden, so they can be easily found 
and accessed in alphabetical order. 


The data is stored in a tree structure. Part of the tree is shown. 


Sunflower 


Fig. 2.1 


(a) (i) State the type of tree shown in Fig. 2.1. 
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(iii) Explain how backtracking is used in a depth-first (post-order) traversal. Use the tree in 
Fig. 2.1 in your explanation. 


(b) The elements in the tree in Fig. 2.1 are read into a linked list producing an alphabetised list. 
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(i) Complete the following table to show the linked list for the data. 


ms Data NextPointer 
0 Begonia 
1 Daisy 
2 Hosta 
3 Lily 
4 Peony 
5 Rose 
6 Sunf Lower 


[2] 
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(ii) Anew plant, Lavender, needs adding to the linked list. The linked list needs to retain its 


(iii) Hosta needs removing from the linked list. 
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alphabetical order. 


Complete the table to show the linked list after Lavender is added. 


ie Data NextPointer 
0 Begonia 
1 Daisy 
2 Hosta 
3 Lily 
4 Peony 
5 Rose 
6 Sunf Lower 


Explain how a data item is removed from a linked list. Use the removal of Hosta in your 


answer. 


[3] 
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(iv) The linked list is stored as a 2D array with the identifier pLantList. The index of the 
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first element of the linked list is stored in the identifier FirstElement. 
All contents of the linked list need to be output in alphabetical order. 


Write an algorithm to follow the pointers to output the contents of the linked list in 
alphabetical order. 


Add comments to explain your code. 
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9 
A recursive function, GCD, is given in pseudocode. 
function GCD(numi, num2) 
if num2 == 0 then 
return num1 
else 
return GCD(num2, num1 MOD num2) 
endif 


endfunction 


(a) The function uses branching. 


(i) Identify the type of branching statement used in the function. 


Ri iryn uae aude actrees says dnecnai aalee ial ureaeaieametna do tae andetiw/obaue Gel estucanctioa dimeric ates tacanaranateasint [1] 
(ii) Explain the difference between branching and iteration. 
SiS ei eee cia ata Saute gedaan cg asad oats bachepstacese eich NE [2] 
(iii) Identify the two parameters in the function. 
Dc cpdepaae bath oead Mica OA Gye bacco end ence pinel ae ed A eee eee ee 
2, aisha cape mage nc iets aaa caged edineee dag shane aaneonsede Nebdubuemaebcatwamadandeneededbabadaeyacantde ceou eed cguanedaiwenaléanahened 
[1] 


(iv) State whether the parameters should be passed by value, or by reference. Justify your 
answer. 
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(v) Describe the arithmetic operation of MOD. Use an example in your answer. 


(b) Trace the recursive function when it is called by the statement GCD(250, 20). Give the final 
value returned. 


lars t le =149 11 i=) [0 = ase er ane ane te eae eee ae ee nn ae nee emcee tre eine tree nemo an ter eee eee eee ee 
[3] 
(c) The function has been rewritten using iteration instead of recursion. 
(i) State one benefit and one drawback of using iteration instead of recursion. 
PE UN tse em ee nc er ew meee ey ee eno aes 
gel Loc eee ee ene ee eee eee eer eee ee er ee et eee ee ee 
[2] 
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(ii) Complete the missing statements in this iterative version of the function. 
function newGCD(num1i, num2) 
temp = 0 


WHILE] (NUM2 |= Leese ) 


NUM2Z = NUML MOD Qo ceeeseeeeeeeeen 
numi = temp 

endwhile 

PO CUI, ensdstetdeataaseincnn 


endfunction 
[4] 
Mabel is a software engineer. She is writing a computer game for a client. In the game the main 
character has to avoid their enemies. This becomes more difficult as the levels of the game 
increase. 


(a) Mabel uses decomposition to design the program. 


Explain how decomposition can aid the design of this program. 


(b) The computer game allows a user to select a character (e.g. name, gender). They can then 
choose a level for the game (easy, normal, challenging). The user controls their character by 
moving it left or right. The character can jump using space bar as an input. If the character 
touches one of the enemies then it loses a life. The character has to make it to the end of the 
level without losing all their lives. 


The game is designed in a modular way. 
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(i) One sub-procedure will handle the user input. 


Describe three other sub-procedures Mabel could create for the given game description. 


(ii) Describe the decision that the program will need to make within the user input sub- 
procedure and the result of this decision. 
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(c) The game's ‘challenging’ level has intelligent enemies that hunt down the character in an 
attempt to stop the user from winning. The program plans the enemies’ moves in advance to 
identify the most efficient way to stop the user from winning the game. 


The possible moves are shown in a graph. Each node represents a different state in the 
game. The lines represent the number of moves it will take to get to that state. 
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(d)* Mabel has been told that true programmers write programs in a text editor, and do not use 
IDEs. Mabel does not agree with this statement. 


Discuss the use of an IDE in the development of this program. 
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A 1-dimensional array stores the following data: 


(a) The array needs sorting into descending order. 


(b) An insertion sort can be used to sort the array instead of a merge sort. 
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Index 


0 


1 


Data 


2 


18 


12 


Describe how a merge sort would sort the given array into descending order. 


Explain why an insertion sort might use less memory than a merge sort. 
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6* Benedict runs a social networking website. He has been told he should use data mining to help 
him enhance and improve his website. 


Evaluate the use of data mining to help Benedict enhance and improve his social networking 
website. 
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Section B 
7  Aprogram is needed to plan the layout of a garden. 


The program will allow the user to create an image of the garden, for example: 


Flower bed 


Path 


(a) The programmer will use abstraction to produce the program interface to represent the 
garden. 


(i) Give two different examples of how abstraction has been used to produce the layout of 
the garden. 


AU eet se eee eeese srt te a cel gaiee cine Peto th tenes es eemace ea aeeatsccteg ate acces ae ee otitis hence nsaraee aa ee 
eda esc esos eae estes ees cece caceatecaeear it ont esenee mace Sod ne es eeeieetnsenees ance bed nem neccsasast ee: 
[2] 
(ii) Explain the need for abstraction in the production of this program. 
se bute Mactan aseP theater eae ae aenieemeacadacateeeseaadaeaheeoonameare eda eeaaietce ac aatoneeetaratiengestie-eteaetecaee [3] 
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(iii) The user needs to input data into the program to set up their garden layout. 


Identify three pieces of data that the user may input into this program. 


(b) The program is to be built using object oriented programming. 
All items that can be added to the garden are declared as instances of the class GardenItem. 


The class has the following attributes: 


Attribute Description Example 
itemName The name of the item Flowerbed 
length The length of the item in metres | 2 
width The width of the item in metres | 1 


(i) The constructor method sets the attributes to values that are passed as parameters. 
Write pseudocode or program code to declare the class GardenItem and its constructor. 


All attributes should be private and initialised through the constructor (e.g. daisies = 
new GardenItem("Flowerbed",2,1) ). [4] 
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(ii) The trees in the garden layouts are defined by the class Tree. This class inherits from 
GardenItem. 


The class Tree has the additional attributes: height, sun, shade. 
If sun is true then the tree can grow in full sun, if it is false then it cannot. 
If shade is true then the tree can grow in full shade, if it is false then it cannot. 


The length and width of a tree are the same. Only one value for these measurements is 
passed to the constructor. 


Write an algorithm, using pseudocode or program code, to declare the class Tree. 
Declare all attributes as private. 
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(iii) +The Common Oak is a type of tree. It has a maximum height, length and width of 40m. 


(iv) 
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It can grow in sun and shade. 


Write a statement, using pseudocode or program code, to declare an instance of tree for 
the Common Oak. Give the object the identifier firstTree. 


The classes GardenItem and Tree use get and set methods to access and alter their 
private attributes. 


Write the get method getItemName and set method setItemName for class 
GardenItem. The set method takes the new value as a parameter. 


Do not write any other methods, or re-declare the class. 
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(v) The trees in the garden layouts are stored in a 1-dimensional array, treeArray. The 
array can store a maximum of 1000 items. The array has global scope. 


A procedure, findTree, takes as parameters: 


The maximum height of a tree 

The maximum width of a tree 
Whether the tree can live in full sun 
Whether the tree can live in full shade. 


It searches the array, treeArray, for all trees that do not exceed the maximum height 
and width, and that can grow in the conditions available. If there are no suitable trees, a 
suitable message is output. 

It outputs the name and details of the trees found in an appropriate message. 


Call the get methods, getItemName, getHeight, getWidth, getSun, getShade, to 
access the attributes. 


Write, using pseudocode or program code, the procedure findTree. 
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(c)* The programmer is designing the program to make use of caching and re-useable 
components. 


Explain and evaluate the use of caching and re-useable components in the design of the 
garden program. 
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